

| Course Title:                | COE                                        |
|------------------------------|--------------------------------------------|
| Course Number:               | 328                                        |
| Semester/Year<br>(e.g.F2016) | F2024                                      |
| Instructor:                  | Arghavan Asad                              |
| Assignment/Lab<br>Number:    | 6                                          |
| Assignment/Lab Title:        | Design of A Simple Central Processing Unit |
| :<br>Submission Date         | 2024-12-12                                 |
| Due Date:                    | 2024-12-12                                 |
|                              |                                            |

| Student   | Student    | Student   | Section | Signature*          |  |  |  |
|-----------|------------|-----------|---------|---------------------|--|--|--|
| LAST Name | FIRST Name | Number    |         |                     |  |  |  |
| Nimalraaj | Sharllene  | 501180933 | 21      | Sharllene Nimalraaj |  |  |  |
|           |            |           |         |                     |  |  |  |
|           |            |           |         |                     |  |  |  |

### **Table of Contents**

#### 1. Introduction

a. Description of the overall lab and the components

### 2. Components

a. Description of components: Latch1, Latch2, 4:16 Decoder and FSM

#### 3. Problem Set 1 ALU

- a. Description of the problem
- b. Purpose of inputs and outputs
- c. Table of Microcodes
- d. Block schematic and waveform

#### 4. Problem Set 2 ALU

- a. Description of the problem
- b. Purpose of inputs and outputs
- c. Table of Microcodes
- d. Block schematic and waveform

#### 5. Problem Set 3 ALU

- a. Description of the problem
- b. Purpose of inputs and outputs
- c. Table of Microcodes
- d. Block schematic and waveform

#### 6. Conclusion

# **Introduction:**

This lab focuses on the implementation and design of a simple CPU in a VHDL environment, which will be implemented on an FPGA board. The CPU consists of an arithmetic and logic unit (ALU), a control unit, a memory and an input/output unit. The ALU performs various arithmetic and logical operations on 2 8-bit inputs A and B and produces an output. The control unit then supplies the opcodes to the ALU, which defines the operations to be performed. The memory is simulated by a finite-state machine (FSM), which generates the current state signal that controls the ALU's operation.

# **Components:**

During this lab the following components were used, Latch1 and 2, FSM, and a 4to16 decoder.

# **Basic Latch (Latch 1)**

The basic latch outlined in this lab is the main component of the storage unit. It takes in a binary number as an input and gives it out as an output for each cycle.

The circuit uses 2 basic latches for each binary number.

### Circuit Diagram for Latch:



#### Waveform for Latch:



Truth Table for Latch1 (and Latch2):

| CLK | D | Q(t+1) |
|-----|---|--------|
| 0   | X | Q(t)   |
| 1   | 0 | 0      |
| 1   | 1 | 1      |

Latch 2

## **Description**:

Latch 2 functions similarly to Latch 1 but is used for a different input channel. This modular design allows the system to process multiple data streams concurrently. The circuit

diagram and truth table illustrate its role in the CPU, and the waveform file confirms its operation under clocked conditions.

#### Component's Circuit Diagram:



#### Component Waveform:



### 4:16 Decoder

The 4:16 Decoder was a component designed to take in the 4-bit state output of the FSM and give out a unique 16-bit output for each state, which selects one operation for the ALU. The mapping facilitates the control of multiple ALU functions using a compact opcode format. The decoder's truth table, block diagram, and simulation waveforms demonstrate its role in the control unit.

### Component's Circuit Diagram:



#### Waveform:



#### Truth Table for Component:



## Finite State Machine (FSM)

The FSM serves as a program counter, cycling through predefined states to sequence operations. Each state corresponds to an opcode fed into the decoder. The FSM ensures orderly execution of instructions, with a state transition diagram and simulation results highlighting its operation. Modifications were made to adapt the FSM to our student numbers.

Circuit Diagram:



#### Waveform:



### Truth Table for Component:

| Currer | nt State | Input | Next  | Next State Out |   | Flip Flo | p Inputs   |
|--------|----------|-------|-------|----------------|---|----------|------------|
| Α      | В        | 1     | Anext | Bnext          | Υ | DA       | <b>D</b> B |
| 0      | 0        | 0     | 0     | 0              | 0 | 0        | 0          |
| 0      | 0        | 1     | 0     | 1              | 0 | 0        | 1          |
| 0      | 1        | 0     | 0     | 0              | 1 | 0        | 0          |
| 0      | 1        | 1     | 1     | 0              | 1 | 1        | 0          |
| 1      | 0        | 0     | 0     | 0              | 0 | 0        | 0          |
| 1      | 0        | 1     | 1     | 0              | 0 | 1        | 0          |
| 1      | 1        | 0     | X     | X              | Х | X        | X          |
| 1      | 1        | 1     | X     | X              | X | X        | X          |

# Arithmetic Logical Unit (ALU)

## **ALU 1:**

The ALU (Arithmetic Logic Unit) serves as the processor that determines the operation to perform on the inputs based on the state of the FSM (Finite State Machine). It has five inputs:

- 1. Clock
- 2. A (binary input)
- 3. **B** (binary input)
- 4. student id
- 5. **OP** (operation code)

Inputs **A** and **B** are binary numbers that act as the inputs to the storage unit, provided that **data\_in** is set to 1. The **Clock** input toggles between 0 and 1. On a rising edge (when the clock transitions from 0 to 1), the ALU reads the value of the **OP** input, which is produced by the decoder. The ALU then executes a switch statement that matches the value of **OP** to a corresponding case, performing the specified operation on **A** and **B** as outlined in the table provided in the lab manual.

In this application of the ALU, student id is not used.

There are 3 outputs for the ALU;

- 1. Neg
- 2. R1
- 3. R2

Neg outputs 1 if the number is negative and lights up an LED on the 7-segment display. R1 and R2 are 4-bit outputs, which can give an 8-bit output when combined. Each bit goes to the 7-segment display to output the result in hexadecimal.

BDF:



| Function # | Microcode         | Boolean Operation /<br>Function |
|------------|-------------------|---------------------------------|
| 1          | 00000000000000001 | sum(A, B)                       |
| 2          | 00000000000000010 | diff( <b>A</b> , <b>B</b> )     |
| 3          | 0000000000000100  | $\overline{A}$                  |
| 4          | 000000000001000   | $\overline{A \cdot B}$          |
| 5          | 000000000010000   | $\overline{A + B}$              |
| 6          | 000000000100000   | A · B                           |
| 7          | 000000001000000   | $A \oplus B$                    |
| 8          | 000000010000000   | A + B                           |
| 9          | 0000000100000000  | $\overline{A \oplus B}$         |

Table 3.1: ALU problem set 1 microcode.

| Si       | mulation V                  | Vaveform Edit    | or - [Final_lab.sim  | wwf (Read-Only)] |            |            |                 |          |          |                 |           |          |                         |            |           |           |            |                      |                       | -             | 0                        | ×        |
|----------|-----------------------------|------------------|----------------------|------------------|------------|------------|-----------------|----------|----------|-----------------|-----------|----------|-------------------------|------------|-----------|-----------|------------|----------------------|-----------------------|---------------|--------------------------|----------|
| File     | Edit View Simulation Help 👦 |                  |                      |                  |            |            | arch altera.com | m 🐧      |          |                 |           |          |                         |            |           |           |            |                      |                       |               |                          |          |
| l la     | <b>a</b> , , , , , ,        | 0 A Z X          | I XH WW XC XH        | )(2 )(8   ₹° ₹°  | · ·        |            |                 |          |          |                 |           |          |                         |            |           |           |            |                      |                       |               |                          |          |
| Mast     | er Time Bar:                | 0 ps             |                      |                  | Pointe     | r: 28.2 ns |                 |          | In       | iterval: 28.2 n | s         |          |                         | Start:     |           |           |            | End:                 |                       |               |                          |          |
|          | Name                        | Value at<br>0 ps | 0 ps 10.0 ns<br>0 ps | 20.0 ns          | 0.0 ns 40  | 0 ns 50.   | ns 60           | .0 ns 70 | 0 ns 80  | i.0 ns 90       | .0 ns 100 | 0 ns 110 | 0 <sub>;</sub> 0 ns 120 | 0.0 ns 130 | 0 ns 140  | 0,0 ns 15 | 0.0 ns 1   | 60 <sub>,</sub> 0 ns | 170 <sub>,</sub> 0 ns | 180,0 ns      | 190 <sub>,</sub> 0 ns 20 | 0.0 ns A |
| 15-      | Clk                         | B 0              |                      |                  |            |            |                 |          |          |                 |           |          |                         |            |           |           |            |                      |                       | $\neg$        |                          | _        |
| <u> </u> | > A                         | H 15             |                      |                  |            |            |                 |          |          |                 | 1         | 5        |                         |            |           |           |            |                      |                       |               |                          | _        |
| in       | > B                         | H 46             | k ===                |                  |            |            |                 |          |          |                 | 4         | 16       |                         |            |           |           |            |                      |                       |               |                          | _        |
| <b>9</b> | > op                        | В 00000000       | 00000000000          | 00001 00000      | 0000000010 | 00000000   | 00000100        | 0000000  | 00001000 | 00000000        | 000010000 | 0000000  | 000100000               | 0000000    | 001000000 | 0000000   | 0010000000 | Х                    | 000                   | 0000000000000 | )                        |          |
| *        | > R1                        | H 0              | k 🗀                  | 0                | X          |            |                 | A        | X        | В               | Х         | 8        | X                       | 4          | X         | 3         | X          | 7                    | $\rightarrow$         | 0             |                          | _        |
| 25       | > R2                        | н 0              |                      | 0                | X          | 3          |                 | E        | X        | F               | X         | A        | X                       | 0          | X         |           | 5          |                      | _X                    | 0             |                          |          |
| 25       | neg                         | B 0              |                      |                  |            |            |                 |          |          |                 |           |          |                         |            |           |           |            |                      |                       |               |                          | _        |

### **ALU 2:**

The Arithmetic Logic Unit (ALU) is the component responsible for determining the operation to perform on the inputs, guided by the state of the Finite State Machine (FSM). It accepts the following five inputs:

- 1. Clock
- 2. **A**
- 3. **B**
- 4. student\_id
- 5. **OP**

Inputs **A** and **B** are binary numbers that serve as the inputs to the storage unit whenever **data\_in** is set to 1. The **Clock** input alternates between 0 and 1. On the rising edge (when the Clock transitions from 0 to 1), the ALU reads the value of the **OP** input, which is the output of the decoder. It then executes a corresponding operation on **A** and **B** using a switch statement, where each case corresponds to a specific operation as outlined in the lab manual.

The **student\_id** input serves no functional purpose in this part.

### BDF:



#### Microcode:

| Function # | Operation / Function                                            |
|------------|-----------------------------------------------------------------|
| 1          | Produce the difference between A and B                          |
| 2          | Produce the 2's complement of <b>B</b>                          |
| 3          | Swap the lower 4 bits of <b>A</b> with lower 4 bits of <b>B</b> |
| 4          | Produce null on the output                                      |
| 5          | Decrement <b>B</b> by 5                                         |
| 6          | Invert the bit-significance order of A                          |
| 7          | Shift <b>B</b> to left by three bits, input bit = 1 (SHL)       |
| 8          | Increment A by 3                                                |

```
LIBRARY ieee;
    USE ieee.std_logic_1164.all;
2
    USE ieee.std_logic_unsigned.all;
   USE ieee.numeric_std.all;
6 Hentity ALU mod is -- ALU unit includes Reg. 3
 7 ⊟port (
8
       clk, res : in std logic;
       Reg1, Reg2: in unsigned (7 downto 0); -- 8-bit inputs A & B from Reg. 1 & Reg. 2
       opcode: in unsigned(15 downto 0); -- 8-bit opcode from Decoder
10
11
       R1, R2 : out unsigned(3 downto 0);
       neg : out std_logic
12
13
       );
    end ALU mod;
14
15
16 Earchitecture calculation of ALU mod is
17 <sup>L</sup>
       signal result : unsigned(7 downto 0); -- 8-bit Result
18 ⊟
       begin
19 ⊟
       process (clk, res, opcode)
20 |
21 =
          begin
             if res = '1' then
                result <= (others => '0');
neg <= '0';
22
23
24
             end if;
25
              --elsif (clk'EVENT AND clk = '1') then
26 😑
                case opcode is
                --elsif (clk'EVENT AND clk = '1') then
25
26 ⊟
                   case opcode is
27
                      when "0000000000000001" =>
28
                          -- Produce the difference between A and B
```

```
29 🖨
                       if (Reg1 >= Reg2) then
30
                          result <= Reg1 - Reg2;
                          neg <= '0';
31
32
                       else
33
                         result <= Reg2 - Reg1;
                          neg <= '1';
34
35
                       end if;
36
37
                    when "0000000000000010" =>
                       -- Produce the 2's complement of B
38
                       result <= not(Reg2) + 1; -- 2's complement
39
                       neg <= '0';
40
41
42
                    when "0000000000000100" =>
43
                       -- Swap the lower 4 bits of A with lower 4 bits of B
44
                       result <= Reg2(3 downto 0) & Reg1(7 downto 4);
                       neg <= '0';
45
46
                    when "000000000001000" =>
47
                       -- Produce null on the output
48
                       result <= (others => '0');
49
50
                       neq <= '0';
```

```
when "000000000010000" =>
                            -- Decrement B by 5
53
54
                            if (Reg2 >= 5) then
                               result <= Reg2 - 5;
55
                               neg <= '0';
56
57
     else
                               result <= (others => '0'); -- Set to 0 if underflow
neg <= '1';</pre>
58
59
60
                           end if;
61
                        when "000000000100000" =>
62
                            -- Invert the bit-significance order of A
63
64
                            result <= Reg1(0) & Reg1(1) & Reg1(2) & Reg1(3) &
65
                                    Reg1(4) & Reg1(5) & Reg1(6) & Reg1(7); -- Reverse bits
                           neg <= '0';
66
67
                        when "0000000001000000" =>
68
                           -- Shift B to the left by 3 bits, input bit = 1 (SHL) result <= (Reg2 sll 3) or "00000111"; -- SHL by 3 and fill with 1
69
70
71
                           neg <= '0';
72
                        when "0000000010000000" =>
73
74
                            -- Increment A by 3
75
                           result <= Reg1 + 3;
76
                           neg <= '0';
77
64
                          result \leq Reg1(0) & Reg1(1) & Reg1(2) & Reg1(3) &
65
                                   Reg1(4) & Reg1(5) & Reg1(6) & Reg1(7); -- Reverse bits
                          neg <= '0';
66
67
68
                       when "0000000001000000" =>
69
                          -- Shift B to the left by 3 bits, input bit = 1 (SHL) result <= (Reg2 sll 3) or "00000111"; -- SHL by 3 and fill with 1 neg <= '0';
70
71
72
73
                       when "0000000010000000" =>
74
                          -- Increment A by 3
                          result <= Reg1 + 3;
75
76
                          neg <= '0';
77
78
                       when others =>
79
                          -- Don't care, do nothing
                          result <= (others => '-'); -- Undefined neg <= '0';
80
81
82
                   end case;
83
                --end if;
84
         end process;
85
86
         R1 <= result(3 downto 0);
87
         R2 <= result(7 downto 4);
88
      end calculation;
89
```



### **ALU 3:**

ALU from Problem 1 is used to incorporate an additional data input — the **student\_id** — which is provided as an output from the FSM component of the Control Unit. The updated ALU3 processes three inputs: **Reg1**, **Reg2**, and **student\_id**.

In this part, the **student\_id** input is utilized by the ALU to determine if its least significant bit (LSB) is 1 or 0. Since an LSB of 1 indicates an odd number and an LSB of 0 indicates an even number, the ALU assigns a new output, **E**, which outputs 1 for odd numbers and 0 for even numbers. This **E** signal is then sent to the 7-segment display, where an **if statement** controls the display to show "n" for odd numbers and "y" for even numbers.

Function that was chosen: **FUNCTION 3 (below)** 

c) For each opcode submitted to the ALU, display 'y' if the **student\_id** signal has an odd parity and 'n' otherwise

#### BDF Screenshot:



```
USE ieee.std_logic_1164.all;
USE ieee.numeric_std.all;
 5 ⊟entity
6 ⊟port (
7 | clk,
    ⊟entity ALU_P3 is -- ALU_P3 unit includes Reg. 3
         Reg1, Reg2: in unsigned(7 downto 0); -- 8-bit inputs A & B from Reg. 1 & Reg. 2 opcode: in unsigned(15 downto 0); -- 8-bit opcode from Decoder result: out unsigned (3 downto 0);
10
         student_id : in unsigned(3 downto 0) -- 4-bit student_id
11
12
13
14
     end ALU_P3;
15
16
17
18
19
   Barchitecture calculation of ALU_P3 is
         -- Check parity of student_id and set result accordingly signal parity_bit : std_logic; -- Signal to store parity
            -- Calculate parity of student_id (odd parity)
parity_bit <= '1' when (student_id(0) xor student_id(1) xor student_id(2) xor student_id(3)) = '1' else '0';
20
21
22
23
24
25
             process (clk, res, opcode)
            begin
if res = '1' then
                result <= (others => '0');
--elsif (clk'EVENT AND clk = '1') then
26
22
      F
                  process (clk, res, opcode)
 23
                  begin
                       if res = '1' then
 24
      result <= (others => '0');
 25
 26
                       --elsif (clk'EVENT AND clk = '1') then
 27 Ė
 28 ⊟
                            if parity_bit = '1' then
 29
                                  -- Set result to 'y' (binary for 'y')
                                 result <= "1111"; --
                                                                   'у'
 30
 31
 32
                                 -- Set result to 'n' (binary for 'n')
                                 result <= "0000"; -- 'n'
 33
 34
                            end if;
 35
                       end if;
                  end process;
 36
       end calculation;
 37
 38
```

# **Circuit Diagrams:**



Circuit Version 1 with ALU 1

After realizing that the circuit diagram needed to be changed for ALU2 and 3, it was completely redesigned to the one below.



Circuit Diagram for ALU 2

# References

Brown, S. D., & Vranesic, Z. G. (2009). Fundamentals of Digital Logic with VHDL Design. New York, United States: McGraw-Hill Education.

# **Conclusion:**

The successful design and implementation of a simple Central Processing Unit (CPU) provided valuable insight into the fundamental components and operation of modern computer architecture. This lab emphasized the integration and coordination of key subcomponents, including the Arithmetic Logic Unit (ALU), Control Unit (incorporating a finite state machine and decoder), registers, and input/output displays.

Through the design and synthesis process, concepts such as data storage, control sequencing, and functional simulation were applied. By using VHDL for hardware description, the CPU's operational logic was effectively translated into a functional hardware model, capable of executing arithmetic and logical operations. The structured approach of developing each subcomponent independently before integrating them into a complete system reinforced the modular nature of digital design.

Additionally, functional testing and simulation using Quartus software allowed for the verification and validation of the CPU's performance. The waveform analysis confirmed that the CPU correctly executed

the specified operations, cycling through control states and producing accurate results on the 7-segment displays.

This lab reinforced key principles of digital system design, including modular design, synchronization, and binary arithmetic. The hands-on experience with FPGA implementation bridged the gap between theoretical knowledge and practical application. The ability to design, simulate, and test a functioning CPU lays a strong foundation for more complex digital design projects in the future.